package com.lzx.adx.report.controller.v1.aqy;


import cn.hutool.core.collection.CollectionUtil;
import cn.hutool.core.util.IdUtil;
import cn.hutool.core.util.URLUtil;
import cn.hutool.http.HttpRequest;
import cn.hutool.http.HttpUtil;
import com.alibaba.fastjson.JSONObject;
import com.lzs.adx.commmon.utils.JsonUtils;
import com.lzs.adx.commmon.utils.Result;
import com.lzx.adx.report.bean.mapper.ReportMapper;
import com.lzx.adx.report.cache.AccountLocalCache;
import com.lzx.adx.report.dto.AccountDTO;
import com.lzx.adx.report.dto.ReportDTO;
import com.lzx.adx.report.model.aqy.AqyRequest;
import com.lzx.adx.report.service.ReportService;
import com.lzx.adx.report.util.AdPerUtil;
import com.lzx.adx.report.util.biz.product.KkChannelHelper;
import lombok.extern.slf4j.Slf4j;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import javax.servlet.http.HttpServletRequest;
import java.nio.charset.StandardCharsets;
import java.util.*;

@RequestMapping("/aqy/kk")
@RestController
@Slf4j
public class AqyKkController {


    @Autowired
    private ReportService reportService;

    @Autowired
    private ThreadPoolTaskExecutor reportExecutor;

    @Autowired
    private ReportMapper reportMapper;

    public static final   String apiDesc="爱奇艺-夸克";



    @GetMapping("/report")
    public ResponseEntity report(AqyRequest aqyRequest, HttpServletRequest request){
        ReportDTO reportDTO=reportMapper.toReportDTO(aqyRequest);
        reportDTO.setBizRequestId(IdUtil.fastSimpleUUID()+reportDTO.getDspId());
        reportDTO.setCreateTime(new Date());
        reportDTO.setUpdateTime(new Date());
        reportDTO.setExtend(JsonUtils.toJsonString(aqyRequest));
        reportDTO.setTraceTime(String.valueOf(System.currentTimeMillis()/1000));
        reportDTO.setImeiSum(aqyRequest.getImei());
        reportDTO.setImei("");
        reportDTO.setOaidSum(aqyRequest.getOaidSum());
        reportExecutor.execute(()->{
            reportService.saveData(reportDTO);
        });

        AccountDTO accountDTO = AccountLocalCache.getInstance().get(aqyRequest.getDspId());

        String finalUrl= KkChannelHelper.covertUrlReport(accountDTO,reportDTO);

        log.info("账号为{},完整的爱奇艺-夸克请求地址为{}",aqyRequest.getDspId(),finalUrl);
        //2.2调用饿了嘛，上报接口
        String body = HttpUtil.createGet(finalUrl).execute().body();
        log.info("账号为{} 爱奇艺接收了-夸克，上报的接口，响应的结果为{}",aqyRequest.getDspId(),body);

        return ResponseEntity.ok(new Result());

    }



    /**
     * 饿了么回传

     * @return ResponseEntity
     * @throws Exception
     */
    @GetMapping("callback")
    public ResponseEntity callBackUrl(String requestId) throws Exception {
        String eventType="1";

        //1.把转换结果更新到数据库
        Map<String,Object> params=new HashMap<>();
        params.put("bizRequestId",requestId);
        List<ReportDTO> list = reportService.list(params);
        ReportDTO reportDTO;
        if(CollectionUtil.isNotEmpty(list)){
            reportDTO = list.get(0);
            reportDTO.setResultType(eventType);
            reportDTO.setResultTime(String.valueOf(System.currentTimeMillis()));
            reportDTO.setUpdateTime(new Date());
            reportService.updateData(reportDTO,eventType);
        }else{
            log.error("当前流水号，系统当前不存在");
            return ResponseEntity.status(HttpStatus.BAD_REQUEST).build();
        }

        //2.从缓存加载配置
        AccountDTO accountDTO = AccountLocalCache.getInstance().get(reportDTO.getDspId());
        String sspExtend = accountDTO.getSspExtend();
        //如果不为空，且sspExtend
        if(StringUtils.isNotBlank(sspExtend)){
            JSONObject jsonObject = JSONObject.parseObject(sspExtend);
            Double per = jsonObject.getDouble("per");
            if(Objects.nonNull(per)){

                if(!AdPerUtil.randomPer(per)){
                    log.info("流水号为 {} 超出了比例外，本次随机的值为{}，dspId为{}",reportDTO.getBizRequestId(),per,reportDTO.getDspId());
                    return ResponseEntity.ok(new Result());
                }
            }
        }

        String callback = reportDTO.getCallback();
        String decodeUrl = URLUtil.decode(callback, StandardCharsets.UTF_8);

        //4.拼装最好的完整链接
        String finalResultUrl=decodeUrl+"&event_type=0";


        log.info("elm给{}上报回传结果，完整的URl{}",apiDesc,finalResultUrl);
        HttpRequest body = HttpUtil.createGet(finalResultUrl);
        String result = body.execute().body();
        log.info("账号为{} 爱奇艺接收了夸克的回传接口，响应的结果为{}",accountDTO.getId(),result);



        return ResponseEntity.ok(new Result());
    }

}
